Bài tập thực hành 1 
Cài đặt thuật toán tìm kiếm DFS và BFS bằng Python 
1. Hướng dẫn 
1.1 Mã giả thuật toán 


Đầu vào: trạng thái bắt đầu, hàm successor, hàm kiểm tra trạng thái đích 


Đầu ra: kế hoạch tìm được (chuỗi các hành động để đi từ trạng thái bắt đầu đến trạng thái đích) 


Quá trình thực hiện: 
°ồ = Khởi tạo: 
— fringe: gồm một kế hoạch ứng với trạng thái bắt đầu 
— closed set: róng 
* Trong khi £ringe chưa rỗng: 
—  Láy một kế hoạch ra khỏi fringe theo một chiến lược nào đó 
—  Néu kế hoạch này đi tới đích (dùng hàm kiểm tra trạng thái đích): RETURN kế hoạch! 
—  Néu trạng thái cuối của kế hoạch này chưa có trong closed set: 


Đưa trạng thái vào closed set 


Mở rộng ra (dựa vào hàm successor) và đưa các kế hoạch mới vào £ringe 


*  Néura được khỏi vòng lặp nghĩa là: không tim thay lời giải 


1.2Sample source code (BES) 


Đoạn code sau cài đặt BFS theo phương pháp đơn giản. 


1. Chọn 1 dinh bat kỳ n, viéng thăm một đỉnh ké i chưa viéng thăm của 
đỉnh này, đánh dấu dinh i này đã viếng thăm, thêm vào queue 

2. Nếu không còn đình kể, lay một đỉnh mới từ đầu queue 

3. Lặp lại bước 1 và 2 cho đến khi queue rồng hoặc tìm thấy đỉnh đích 


VA' E'S" "org 

'B' ['D', 'E'], 

"Cc" Fi [E]; 

"DY s Fg 

"ue: que, 

"BU a 
) 
visited = [] 4 List to keep track of visited nodes. 
queue - [] #Initialize a queue 


def bfs(visited, graph, start,end): 
visited.append(start) 
queue.append(start) 


while queue: 

S = queue.pop(0) 

print (s, end = " ") 

if s == end: 
return 

for neighbour in graph[s]: 

if neighbour not in visited: 

visited.append(neighbour) 
queue.append (neighbour) 


# Driver Code 
bfs (visited, graph, 'A','F') 


Đoạn code tiếp theo vẫn cài đặt BFS nhung có xuất ra đường di 


# graph is in adjacent list representation 


graph = { 
UK es ['2"; "3"; '4'], 
OD ee [^5*, Lót 1, 
LG s [*9*, "10" 1]; 
UA re Lay "gs 
rts LIL; 12] 


} 


def bfs(graph, start, end): 
# maintain a queue of paths 
visited = [] 
queue - [] 


# push the first path into the queue 
queue.append([start]) 
while queue: 
get the first path from the queue 
path = queue.pop (0) 
get the last node from the path 
node = path[-1] 
# path found 
if node == end: 
return path 
enumerate all adjacent nodes, construct a new path and push 
it into the queue 
for neighbour in graph.get(node, []): 
if neighbour not in visited: 
new path = list (path) 
new path.append (neighbour) 
queue.append(new path) 


print (bfs(graph, '1', '11")) 


2. Yéu càu bài táp 


2.1 Sinh viên cài đặt lại hai đoạn code máu bên trên. Cho biết kết quá thực thi với 
các đồ thị sau. 


Tìm đường di tir s 9 g. A > Cho đồ thị 3 


2.2 Dựa vào đoạn code máu vé BFS. Sinh viên cài đặt thuật toán DFS và cho biết 
kết quá thực thi DFS với các đồ thị như phán 2.1 


3. Qui định nộp 

- Sinh viên nộp một tap tin nén, có tên là «MSSV».zip hoặc «MSSV».rar chứa 
source code và báo cáo của chương trình. 

- Sinh viên nộp kèm một file báo cáo ghi mức độ hoàn thành công việc của mình 


Bài giống nhau hay nộp file rác sẽ 0 điểm MÔN HỌC. 


